//给定一个 完美二叉树 ，其所有叶子节点都在同一层，每个父节点都有两个子节点。二叉树定义如下： 
//
// 
//struct Node {
//  int val;
//  Node *left;
//  Node *right;
//  Node *next;
//} 
//
// 填充它的每个 next 指针，让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点，则将 next 指针设置为 NULL。 
//
// 初始状态下，所有 next 指针都被设置为 NULL。 
//
// 
//
// 进阶： 
//
// 
// 你只能使用常量级额外空间。 
// 使用递归解题也符合要求，本题中递归程序占用的栈空间不算做额外的空间复杂度。 
// 
//
// 
//
// 示例： 
//
// 
//
// 
//输入：root = [1,2,3,4,5,6,7]
//输出：[1,#,2,3,#,4,5,6,7,#]
//解释：给定二叉树如图 A 所示，你的函数应该填充它的每个 next 指针，以指向其下一个右侧节点，如图 B 所示。序列化的输出按层序遍历排列，同一层节点由 
//next 指针连接，'#' 标志着每一层的结束。
// 
//
// 
//
// 提示： 
//
// 
// 树中节点的数量少于 4096 
// -1000 <= node.val <= 1000 
// 
// 👍 581 👎 0


package leetcode.editor.cn;

//填充每个节点的下一个右侧节点指针

import Entity.Node;
import 分类.二叉树;

public class P116_填充每个节点的下一个右侧节点指针 implements 二叉树 {
    public static void main(String[] args) {
        Solution solution = new P116_填充每个节点的下一个右侧节点指针().new Solution();

    }

    //leetcode submit region begin(Prohibit modification and deletion)

    class Solution {
        public Node connect(Node root) {
            // 题目意思：就是想将【完美二叉树】的每层所有子节点从左到右使用next连接起来，最右的next指向null
            if (root == null) {
                return root;
            }
            connectTwoNode(root.left, root.right);
            return root;
        }

        private void connectTwoNode(Node leftNode, Node rightNode) {
            if (leftNode == null || rightNode == null) {
                return;
            }
            // 连接 leftNode和 rightNode
            leftNode.next = rightNode;
            // 连接同一父节点的两个节点
            connectTwoNode(leftNode.left, leftNode.right);
            connectTwoNode(rightNode.left, rightNode.right);
            // 连接不同父节点的
            connectTwoNode(leftNode.right, rightNode.left);
        }
    }
//leetcode submit region end(Prohibit modification and deletion)


}